# TCP/IP命令
# MTU
命令 netstat -in
可以查看网络接口的 MTU
# IP地址
ifconfig -a
:查看自己的 IP 地址
# 域名
用 12 位数字组成的 IP 地址很难记忆,在实际应用时,用户一般不需要记住 IP 地址,互联网给每个 IP 地址起了一个别名,习惯上称作域名。
域名与计算机的 IP 地址相对应,并把这种对应关系存储在域名服务系统 DNS(Domain Name System) 中,这样用户只需记住域名就可以与指定的计算机进行通信了。
常见的域名包括 com、net 和 org 三种顶级域名后缀,除此之外每个国家还有自己国家专属的域名后缀(比如我国的域名后缀为 cn)。
我们可以使用命令 nslookup
或者 ping
来查看与域名相对应的 IP 地址
# 端口号
IP 地址是用来发现和查找网络中的地址的,但是不同程序如何互相通信呢,这就需要端口号来识别了。如果把 IP 地址比作一间房子 ,端口就是出入这间房子的门。真正的房子只有几个门,但是端口采用 16 比特的端口号标识,一个 IP 地址的端口可以有 65536(即:2^16)个之多!
服务器的默认程序一般都是通过人们所熟知的端口号来识别的。例如,对于每个 TCP/IP 实现来说,SMTP(简单邮件传输协议)服务器的 TCP 端口号都是 25
,FTP(文件传输协议)服务器的 TCP 端口号都是 21
,TFTP(简单文件传输协议)服务器的 UDP 端口号都是 69
。任何 TCP/IP 实现所提供的服务都用众所周知的 1-1023
之间的端口号。这些人们所熟知的端口号由 Internet 端口号分配机构(Internet Assigned Numbers Authority, IANA)来管理。
常用协议对应端口号:
SSH
22
FTP
20 和 21
Telnet
23
SMTP
25
TFTP
69
HTTP
80
SNMP
161
Ping
使用ICMP,无具体端口号
# 封装和分用
# 封装
当应用程序发送数据的时候,数据在协议层次当中从顶向下通过每一层,每一层都会对数据增加一些首部或尾部信息,这样的信息称之为协议数据单元(Protocol Data Unit,缩写为PDU),在分层协议系统里,在指定的协议层上传送的数据单元,包含了该层的协议控制信息和用户信息。如下图所示:
物理层(一层)PDU指数据位(Bit) 数据链路层(二层)PDU指数据帧(Frame) 网络层(三层)PDU指数据包(Packet) 传输层(四层)PDU指数据段(Segment) 第五层以上为数据(data)
# 分用
当主机收到一个数据帧时,数据就从协议层底向上升,通过每一层时,检查并去掉对应层次的报文首部或尾部,与封装过程正好相反。